home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Screensavers 98
/
Screensavers 98.iso
/
ass
/
brawn alarm
/
braun.ms_
/
braun.ms
Wrap
Text File
|
2000-03-28
|
9KB
|
344 lines
'$DEFINE DEBUG ''Define for script development/debugging
'$INCLUDE 'setupapi.inc'
'$INCLUDE 'msdetect.inc'
''Dialog ID's
CONST WELCOME = 100
CONST ASKQUIT = 200
CONST TOOBIG = 300
CONST EXITFAILURE = 400
CONST EXITQUIT = 600
CONST EXITSUCCESS = 700
CONST APPHELP = 900
CONST COPYING = 103
CONST BADPATHDLG = 108
CONST GETPATH = 106
''Bitmap ID
CONST LOGO = 1
GLOBAL WinDrive$
GLOBAL DEST$ ''Default destination directory.
GLOBAL OPTCUR$ ''Option selection from option dialog.
GLOBAL CUIDLL$
GLOBAL MAINDEST$
DECLARE SUB Install
DECLARE FUNCTION MakePath (szDir$, szFile$) AS STRING
DECLARE FUNCTION GetLanguageCode AS INTEGER
DECLARE FUNCTION GetIntl(szKey$) AS STRING
DECLARE FUNCTION GetRealWindowsSysDir AS STRING
DECLARE FUNCTION IsBigEnough(size%) AS INTEGER
DECLARE SUB CopyTheDirectory
DECLARE SUB UpdateWinG32 (szOrig$)
DECLARE FUNCTION OnWin3x LIB "setuphlp.DLL" AS INTEGER
DECLARE FUNCTION VflatdPresent LIB "setuphlp.DLL" AS INTEGER
DECLARE FUNCTION GetRealSystemDir LIB "setuphlp.DLL" (szDir$,cbBuf%) AS INTEGER
DECLARE FUNCTION RestartWindows LIB "setuphlp.DLL" AS INTEGER
DECLARE FUNCTION IsWin32FileNewer LIB "setuphlp.DLL" (szOrig$,szNew$) AS INTEGER
DECLARE SUB RenameFilePlease LIB "setuphlp.DLL" (szOrig$,szNew$)
DECLARE FUNCTION CopyDirectory LIB "MSCUISTF.DLL" (src$, dest$) AS INTEGER
INIT:
CUIDLL$ = "mscuistf.dll" ''Custom user interface dll
HELPPROC$ = "FHelpDlgProc" ''Help dialog procedure
Lang% = 0
SetBitmap CUIDLL$, LOGO
SetTitle "Braun Alarm Clock Screensaver"
szInf$ = GetSymbolValue("STF_SRCINFPATH")
IF szInf$ = "" THEN
szInf$ = GetSymbolValue("STF_CWDDIR") + "BRAUN.INF"
END IF
ReadInfFile szInf$
OPTCUR$ = "1"
DEST$ = "C:\BRAUN"
'$IFDEF DEBUG
i% = SetSizeCheckMode(scmOnIgnore) '' could use scmOff; def = scmOnFatal
WinDrive$ = MID$(GetWindowsDir, 1, 1)
IF IsDriveValid(WinDrive$) = 0 THEN
i% = DoMsgBox("Windows drive ('"+WinDrive$+"') is not a valid drive.", "DEBUG", MB_TASKMODAL+MB_ICONHAND+MB_OK)
GOTO QUIT
END IF
'$ENDIF ''DEBUG
WELCOME:
sz$ = UIStartDlg(CUIDLL$, Lang%+WELCOME, "FInfoDlgProc", Lang%+APPHELP, HELPPROC$)
IF sz$ = "CONTINUE" THEN
UIPop 1
ELSE
GOSUB ASKQUIT
GOTO WELCOME
END IF
Install
QUIT:
ON ERROR GOTO ERRQUIT
IF ERR = 0 THEN
dlg% = EXITSUCCESS
ELSEIF ERR = STFQUIT THEN
dlg% = EXITQUIT
ELSE
dlg% = EXITFAILURE
END IF
QUITL1:
sz$ = UIStartDlg(CUIDLL$, Lang%+dlg%, "FInfo0DlgProc", 0, "")
IF sz$ = "REACTIVATE" THEN
GOTO QUITL1
END IF
UIPop 1
END
ERRQUIT:
i% = DoMsgBox("Setup sources were corrupted!", "Setup Message", MB_OK+MB_TASKMODAL+MB_ICONHAND)
END
ASKQUIT:
sz$ = UIStartDlg(CUIDLL$, Lang%+ASKQUIT, "FQuitDlgProc", 0, "")
IF sz$ = "EXIT" THEN
UIPopAll
ERROR STFQUIT
ELSEIF sz$ = "REACTIVATE" THEN
GOTO ASKQUIT
ELSE
UIPop 1
END IF
RETURN
'**
'** Purpose:
'** Builds the copy list and performs all installation operations.
'** Arguments:
'** none.
'** Returns:
'** none.
'*************************************************************************
SUB Install STATIC
DEST$ = GetWindowsDir
IF IsBigEnough(4) = 0 THEN
GOSUB NOSPACE
ERROR STFERR
EXIT SUB
END IF
UIPop 1
SrcDir$ = GetSymbolValue("STF_SRCDIR")
MAINDEST$=DEST$
CreateDir DEST$, cmoNone
OpenLogFile MakePath(DEST$, "LOGFILE.OUT"), 0
WriteToLogFile ""
WriteToLogFile " User chose as destination directory: '" + DEST$ + "'"
WriteToLogFile "May have had to create the directory: " + DEST$
WriteToLogFile ""
ini$ = MakePath(GetWindowsDir, "BRAUN.INI")
CreateIniKeyValue ini$, "BRAUN", "InstallDir", DEST$ , cmoNone
DEST$ = GetWindowsDir
AddSectionFilesToCopyList "saver", SrcDir$, DEST$
CreateIniKeyValue ini$, "Main", "NumFiles", "1" , cmoNone
CreateIniKeyValue ini$, "Main", "Language", GetIntl("sLanguage") , cmoNone
CreateIniKeyValue ini$, "Main", "Country", GetIntl("sCountry") , cmoNone
DEST$ = GetWindowsSysDir
AddSectionFilesToCopyList "runtime", SrcDir$, DEST$
IF OnWin3x() = 1 THEN
AddSectionFilesToCopyList "dva", SrcDir$, DEST$
IF VflatdPresent() = 0 THEN
CreateSysIniKeyValue GetWindowsDir + "system.ini", "386Enh", "device", GetWindowsSysDir+"dva.386", cmoOverwrite
bInstallDVA% = 1
END IF
END IF
DEST$ = GetRealWindowsSysDir
AddSectionFilesToCopyList "wing32", SrcDir$, DEST$
Dest1$ = MakePath(DEST$,"wing32.dll")
Dest2$ = MakePath(DEST$,"wing32.xxx")
RenameFilePlease Dest1$,Dest2$
CopyFilesInCopyList
''
'' Uncomment this bit if you want the copy facility
''
'' CopyTheDirectory
UpdateWinG32 GetRealWindowsSysDir()
CloseLogFile
EXIT SUB
BADPATH:
sz$ = UIStartDlg(CUIDLL$, BADPATHDLG, "FInfo0DlgProc", 0, "")
IF sz$ = "REACTIVATE" THEN
GOTO BADPATH
END IF
UIPop 1
RETURN
NOSPACE:
sz$ = UIStartDlg(CUIDLL$, TOOBIG, "FInfo0DlgProc", 0, "")
IF sz$ = "REACTIVATE" THEN
GOTO NOSPACE
END IF
UIPop 1
RETURN
END SUB
'**
'** Purpose:
'** Appends a file name to the end of a directory path,
'** inserting a backslash character as needed.
'** Arguments:
'** szDir$ - full directory path (with optional ending "\")
'** szFile$ - filename to append to directory
'** Returns:
'** Resulting fully qualified path name.
'*************************************************************************
FUNCTION MakePath (szDir$, szFile$) STATIC AS STRING
IF szDir$ = "" THEN
MakePath = szFile$
ELSEIF szFile$ = "" THEN
MakePath = szDir$
ELSEIF MID$(szDir$, LEN(szDir$), 1) = "\" THEN
MakePath = szDir$ + szFile$
ELSE
MakePath = szDir$ + "\" + szFile$
END IF
END FUNCTION
FUNCTION GetIntl(szKey$) STATIC AS STRING
szBuf$ = string$(256,32)
cbBuf% = GetProfileString("intl",szKey$,"Engl",szBuf$,256)
IF cbBuf% = 0 THEN
GetIntl="Engl"
ERROR STFERR
END IF
GetIntl = szBuf$
szBuf=""
END FUNCTION
FUNCTION GetRealWindowsSysDir STATIC AS STRING
szBuf$ = string$(260, 32)
cbBuf% = GetRealSystemDir(szBuf$, 260)
IF cbBuf% = 0 THEN
ERROR STFERR
ELSE
IF cbBuf% > 259 THEN
res% = DoMsgBox("Buffer Overflow", "MS-Setup Error", MB_ICONHAND+MB_OK)
ERROR STFERR
END IF
szBuf$ = RTRIM$(szBuf$)
IF MID$(szBuf$, 1, 1) = "\" THEN
szBuf$ = MID$(CURDIR$, 1, 2) + szBuf$
ELSEIF MID$(szBuf$, 2, 1) <> ":" THEN
szBuf$ = MID$(CURDIR$, 1, 3) + szBuf$
END IF
IF MID$(szBuf$, LEN(szBuf$), 1) <> "\" THEN
szBuf$ = szBuf$ + "\"
END IF
GetRealWindowsSysDir = szBuf$
END IF
szBuf$ = ""
END FUNCTION
SUB UpdateWinG32 (szOrig$) STATIC
'
' Here we check the version ourselves of wing32.dll, since
' we can't get version checking for Win32 apps from Win16
'
FileNew$ = MakePath(szOrig$, "wing32.dll")
FileOrig$ = MakePath(szOrig$, "wing32.xxx")
IF IsWin32FileNewer( FileOrig$, FileNew$ ) THEN
RemoveFile FileOrig$, cmoForce
ELSE
RemoveFile FileNew$, cmoForce ' get rid of new file
RenameFilePlease FileOrig$,FileNew$ ' put back old file
END IF
END SUB
FUNCTION GetLanguageCode STATIC AS INTEGER
langname$ = ucase$(GetIntl("sLanguage"))
GetLanguageCode=0
IF langname$ = "ENG" THEN
GetLanguageCode=0
END IF
IF langname$ = "FRC" THEN
GetLanguageCode=1000
END IF
IF langname$ = "FRA" THEN
GetLanguageCode=1000
END IF
IF langname$ = "DEU" THEN
GetLanguageCode=2000
END IF
IF langname$ = "ITA" THEN
GetLanguageCode=3000
END IF
IF langname$ = "ESN" THEN
GetLanguageCode=4000
END IF
IF langname$ = "ESP" THEN
GetLanguageCo